草庐IT

C++ 泛型 vector

全部标签

c++ - 为什么 std::vector::at() 即使启用了优化也需要边界检查?

Windows中的libstdc++-6.dll有问题。这段代码:#include#includeintmain(){std::vectorx(10);std::cout编译很好,但是当我运行它时,我收到一条错误消息说Theprocedureentrypoint_ZSt24__throw_out_of_range_fmtPKczcouldnotbelocatedinthedlllibstdc++-6.dll我的问题是不是如何解决这个问题(这很可能是dll的错误版本,我只需要修复PATH)。然而,这让我意识到了一些意想不到的事情:当我打开优化时,上面的代码运行良好(不管错误的dll),即

c++ - 如何删除 vector 中的元素。 (删除无效)

当我使用“删除”删除vector中的元素时,并没有清除内存。例如,我制作了一个大小为2000的vector。创建后程序使用1,5MB内存。当我执行删除调用时,不会清除任何内容。所有的元素都消失了。但它们仍在内存中。例如:#include#includeusingnamespacestd;intmain(){//Makesavectorof2000itemsvectortest(200000);//Pausefortestpurposesystem("pause");//eraseallelementstest.erase(test.begin(),test.end());//Pause

c++ - 如何调用一个带有多个整数和一个整数 vector 的函数?

问题我正在尝试为一种玩具语言编写解释器,我希望它能够调用位于DLL中的函数。在一些external.dll我有:#includeextern"C"{__declspec(dllexport)voidprint(intval){printf("%i\n",val);}__declspec(dllexport)intadd(inta,intb){returna+b;}...morefunctions**thatIdon'tknowthennamesof**}假设我有一个std::stringfunc;这是DLL中过程的名称,可能是"print"或"add",和一个std::vectorar

c++ - C++ 中的 Memory Tracker 在 vector 初始化期间进入无限循环

我正在尝试通过重载new和delete运算符在C++中编写内存跟踪器。但它会进入循环并一次又一次地调用new。以下是我的代码。#ifndefMEMORY_TRACKER_H_#defineMEMORY_TRACKER_H_#pragmawarning(disable:4290)#pragmacomment(lib,"Dbghelp.lib")#include#include#include#include#include#include#includestaticconstintMAX_TRACES=62;staticconstintMAX_LENGTH=256;staticconst

c# - 使用泛型检查默认值

这个问题在这里已经有了答案:NullordefaultcomparisonofgenericargumentinC#(14个答案)关闭9年前。我希望能够检查一个值是否是其值类型的默认值。理想情况下,我想说:DoSomething(TValuevalue){if(value==default(TValue)){...}}但是,编译器提示它不能对TValue和TValue进行==比较。这是迄今为止我想出的最佳解决方法:DoSomething(TValuevalue){if(value==null||value.Equals(default(TValue))){...}}有没有更优雅/正确的

c# - 为什么 C# 无法从非泛型静态方法的签名中推断泛型类型参数类型?

我进行了以下推理测试:staticclassInferenceTest{staticvoidTakeInt(inta){}staticintGiveInt(){return0;}staticintTakeAndGiveInt(inta){return0;}staticvoidConsumeAction1(Actiona){}staticvoidConsumeFunc1(Funcf){}staticvoidConsumeFunc2a(Funcf){}staticvoidConsumeFunc2b(Funcf){}staticvoidConsumeFunc2c(Funcf){}static

c# - 嵌套泛型语法歧义 >>

显然,C#很容易受到“>>”词法分析器困境的影响asisC++.这段C#代码非常有效,它编译和运行都很好:varList=newDummy("List");varNullable=newDummy("Nullable");varGuid=newDummy("Guid");varx=List>10;vary=List>.Equals(10,20);您必须为上面的Dummy类重载“>”运算符。但编译器设法猜测,在“x”的情况下,意思是使用List、Nullable和Guid局部变量。在'y'情况下,它突然决定将它们视为众所周知类型的名称。这里有一个更详细的描述和另一个例子:http://m

c# - 如何使用强类型反射查找泛型类方法的 MethodInfo?

我想从具有仅在运行时已知的类型参数的泛型类中获取方法的MethodInfo。下面是我如何从非泛型类中获取泛型方法的MethodInfo:classMyClass{publicvoidMyMethod(Targ){}}staticMethodInfoResolve(Typetype){Expression>lambda=(c,a)=>c.MyMethod(a);MethodCallExpressioncall=lambda.BodyasMethodCallExpression;returncall.Method//GetMethodInfoforMyClass.MyMethod.GetG

c# - 简化泛型类型推断

我正在编写一个通用代码,用于处理从多个来源加载数据的情况。我有一个具有以下签名的方法:publicstaticTResultLoadFromAnySource(thisTSectionsection,stringserviceBaseUri,stringnodeName)whereTSection:ConfigurationSectionwhereTResult:IDatabaseConfigurable,new()whereTContract:new()但这有点矫枉过正:当我通过TResult时,我已经知道什么了TContract和TSection确实是。在我的示例中:publici

c# - 对于 C# 无法使用类型约束推断泛型类型参数,是否有解决方法?

EricLippert在他的博文中解释了http://blogs.msdn.com/b/ericlippert/archive/2009/12/10/constraints-are-not-part-of-the-signature.aspx为什么类型推断不考虑约束,这是有道理的,因为不能通过简单地更改类型约束来重载方法。但是,我想找到一种使用两种泛型类型实例化对象的方法,一种可以推断,另一种可以在考虑约束的情况下推断,而无需指定任何类型。给定类型:publicinterfaceI{OtherCreateOther();}publicclassC:I{publicOtherCreate